<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>
    <!-- <button>一个按钮</button> -->
    <script>
        // let btn = document.querySelector('button')
        // // 创建一个对象保存事件名和事件函数
        // let eventObj = {}
        // function addEvent(eventName, fn) {
        //     // 初始化事件名，为一个数组
        //     if (typeof eventObj[eventName] == 'undefined') {
        //         eventObj[eventName] = []
        //     }
        //     // 保存事件
        //     eventObj[eventName].push(fn)
        // }
        // addEvent('打印111', function () {
        //     console.log('111')
        // })
        // addEvent('打印111', function () {
        //     console.log('一一一')
        // })
        // addEvent('打印222', function () {
        //     console.log('2')
        // })
        // addEvent('打印333', function () {
        //     console.log('333')
        // })

        // // 写一个触发函数
        // function trigger(eventName) {
        //     if (typeof eventObj[eventName] != undefined) {
        //         eventObj[eventName].forEach(function (item) {
        //             item()
        //         })
        //     }
        // }
        // trigger('打印111')

        // 改造成类
        class myEvent {
            constructor() {
                this.eventObj = {}
            }

            addEvent(eventName, fn) {
                // 初始化事件名，为一个数组
                if (typeof this.eventObj[eventName] == 'undefined') {
                    this.eventObj[eventName] = []
                }
                // 保存事件
                this.eventObj[eventName].push(fn)
            }

            trigger(eventName) {
                if (typeof this.eventObj[eventName] != undefined) {
                    this.eventObj[eventName].forEach(function (item) {
                        item()
                    })
                }
            }
        }
        
        let a = new myEvent()
        console.log(a)
        a.addEvent('打印111', function() {
            console.log('111')
        })
        a.addEvent('打印111', function() {
            console.log('yiyiyi')
        })

        a.trigger('打印111')







    </script>
</body>

</html>